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IN THE CLAIMS 

1 . (Currently Amended) A method comprising: 

p e rmitting a thr e ad to b e int e rrupted during a first critical region; 

interrupting [[the]] a thread with an interrupt routine during a first critical region ; and 

s e l e ctiv e ly setting the thread to restart at a beginning of the first critical region in 
response to an indication that the thread is working in a critical region , wherein the thread is to 
avoid disabling all interrupts before it enters the first critical region and avoid re-enabling the 
interrupts after exiting the first critical region . 

2. (Original) The method of Claim 1 , wherein the setting the thread to start at the beginning 
of the first critical region comprises: 

setting a stack pointer and program counter so that the interrupted thread restarts at the 
beginning of the first critical region. 

3. (Currently Amended) The method of Claim 1, wherein the first critical region includes 
the acts of: 

s e l e ctiv e ly incrementing a count of a number of times the first critical region has been 
interrupted in response to the first critical region having been previously interrupted; and 

s e l e ctiv e ly saving program stack conditions of the interrupted thread in response to the 
thread not having been interrupted during the first critical region more than a maximum permitted 
number of times. 

4. (Original) The method of Claim 3, wherein the first critical region further includes the acts 
of: 

setting a flag to indicate that a critical region is entered; 

performing critical region interrupt recovery work in response to an indication that the 
first critical region was previously interrupted; and 

attempting to complete first critical region work. 

5. (Original) The method of Claim 4, wherein the critical region interrupt recovery work 
corrects errors that arise from previously interrupting the first critical region prior to its completion. 

6. (Original) The method of Claim 4, wherein the first critical region further includes the acts 
of: 
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s e l e ctiv e ly setting a flag to indicate that critical region work is not being performed in 
response to the critical region work completing; and 

setting to zero the count of the number of times the first critical region was interrupted. 

7. (Original) The method of Claim 1 further comprising: 

marking the thread as having been interrupted during the first critical region. 

8. (Original) The method of Claim 1, further comprising indicating that the thread is not 
operating in a critical region. 

9. (Currently Amended) A method comprising: 

interrupting p e rmitting a thread to b e int e rrupted during a first critical region; 

s e l e ctiv e ly incrementing a count of a number of times the first critical region has been 
interrupted in response to the first critical region having been previously interrupted; and 

sel e ctively saving program stack conditions of the interrupted thread in response to the 
thread not having been interrupted during the first critical region more than a maximum permitted 
number of times , wherein the thread is to avoid disabling all interrupts before it enters the first 
critical region and avoid re-enabling the interrupts after exiting the first critical region . 

1 0. (Currently Amended) The method of Claim 9, further comprising: 
setting a flag to indicate that a critical region is entered; 

s e l e ctively performing critical region interrupt recovery work in response to an indication 
that the first critical region was previously interrupted; and 

clearing a flag indicating the first critical region was previously interrupted. 

1 1 . (Original) The method of Claim 10, wherein the critical region interrupt recovery work 
corrects errors that arise from previously interrupting the first critical region prior to its completion. 

1 2. (Original) The method of Claim 10, further comprising: 
commencing work in the first critical region. 

13. (Currently Amended) The method of Claim 12, further comprising: 

s e l e ctively setting a flag to indicate that critical region work is not being performed in 
response to the critical region work completing; and 

resetting a counter of times the first critical region was interrupted to zero. 
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14. (Currently Amended) The method of Claim 9, further comprising: 
setting a flag to indicate that a critical region is entered; and 

s e l e ctiv e ly commencing work in the first critical region in response to an indication that 
the first critical region was not previously interrupted. 

1 5. (Currently Amended) The method of Claim 14, farther comprising: 

sel e ctiv e ly setting a flag to indicate that critical region work is not being performed in 
response to the critical region work completing; and 

resetting a counter of times the first critical region was interrupted to zero. 

1 6. (Currently Amended) A method comprising: 

s e l e ctiv e ly disabling interrupts of a critical region in response to the critical region having 
been interrupted more than a permitted number of times; and 

commencing critical region work , wherein the thread is to avoid disabling all interrupts 
before it enters the first critical region and avoid re-enabling all interrupts after exiting the first 
critical region . 

1 7. (Currently Amended) The method of Claim 1 6, further comprising: 

s e l e ctively setting a flag to indicate that critical region work is not being performed in 
response to the critical region work completing; 

selectively resetting a counter of times the critical region was interrupted to zero in 
response to the critical region work completing; and 

re-enabling interrupts of the critical region. 

1 8. (Currently Amended) A method comprising: 

interrupting p e rmitting a critical region to bo interrupted ; and 

s e l e ctiv e ly saving stack conditions of an interrupted critical region in response to the 
critical region not having been previously interrupted , wherein a thread that is interrupted is to 
avoid disabling all interrupts before it enters the first critical region and avoid re-enabling the 
interrupts after exiting the first critical region . 

1 9. (Original) The method of Claim 1 8, further comprising: 
commencing work in the critical region. 
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20. (Currently Amended) The method of Claim 19, further comprising: 

s e l e ctively setting a flag to indicate that critical region work is not being performed in 
response to the critical region work completing; and 

s e l e ctiv e ly resetting a counter of times the critical region was interrupted to zero in 
response to the critical region work completing. 

2 1 . (Currently Amended) An article comprising a storage medium, the storage medium 
comprising machine readable instructions stored thereon to: 

interrupt p e rmit a thread to b e int e rrupt e d during a first critical region t 

int e rrupt th e thread with an interrupt routine; and 

s e lectively set the thread to restart at a beginning of the first critical region in response to 
an indication that the thread operates in a critical region , wherein the thread is to avoid disabling 
all interrupts before it enters the first critical region and avoid re-enabling the interrupts after 
exiting the first critical region . 

22. (Original) The article of Claim 21, wherein the instructions to set the thread to restart at 
the beginning of the first critical region comprises instructions to: 

set a stack pointer and program counter so that the interrupted thread restarts at the 
beginning of the first critical region. 

23 . (Currently Amended) The article of Claim 2 1 , wherein the first critical region includes 
instructions to: 

sel e ctively increment a count of a number of times the first critical region has been 
interrupted in response to the first critical region having been previously interrupted; and 

s e l e ctively save program stack conditions of the interrupted thread in response to the 
thread not having been interrupted during the first critical region more than a maximum permitted 
number of times. 

24. (Original) The article of Claim 23, wherein the first critical region further includes 
instructions to: 

set a flag to indicate that a critical region is entered; 

perform critical region interrupt recovery work in response to an indication that the first 
critical region was previously interrupted; and 
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attempt to complete first critical region work. 

25. (Original) The article of Claim 24, wherein the critical region interrupt recovery work 
includes instructions to correct errors that arise from previously interrupting the first critical region prior 
to its completion. 

26. (Currently Amended) The article of Claim 24, wherein the first critical region further 
includes instructions to: 

s e l e ctiv e ly set a flag to indicate that critical region work is not being performed in 
response to the critical region work completing; and 

set to zero the count of the number of times the first critical region was interrupted. 

27. (Original) The article of Claim 21 further comprising instructions to mark the thread as 
having been interrupted during the first critical region. 

28. (Original) The article of Claim 2 1 , further comprising instructions to indicate that the 
thread is not operating in a critical region. 

29. (Original) An apparatus comprising: 

an I/O controller device comprising a processor and a memory device, the I/O controller 
device comprising logic to: 

interrupt p e rmit a thread to b e int e rrupt e d during a first critical region t 

interrupt th e thread with an interrupt routine; and 

s e l e ctively set the thread to restart at a beginning of the first critical region in 
response to an indication that the thread operates in a critical region , wherein the thread is 
to avoid disabling all interrupts before it enters the first critical region and avoid re- 
enabling the interrupts after exiting the first critical region . 

30. (Original) The apparatus of Claim 29, wherein the logic to set the thread to restart at the 
beginning of the first critical region comprises logic to: 

set a stack pointer and program counter so that the interrupted thread restarts at the 
beginning of the first critical region. 

3 1 . (Currently Amended) The apparatus of Claim 29, wherein the first critical region 
includes logic to: 
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s e l e ctiv e ly increment a count of a number of times the first critical region has been 
interrupted in response to the first critical region having been previously interrupted; and 

sel e ctiv e ly save program stack conditions of the interrupted thread in response to the 
thread not having been interrupted during the first critical region more than a maximum permitted 
number of times. 

32. (Original) The apparatus of Claim 3 1 , wherein the first critical region further includes 
logic to: 

set a flag to indicate that a critical region is entered; 

perform critical region interrupt recovery work in response to an indication that the first 
critical region was previously interrupted; and 

attempt to complete first critical region work. 

33. (Original) The apparatus of Claim 32, wherein the critical region interrupt recovery work 
includes logic to correct errors that arise from previously interrupting the first critical region prior to its 
completion. 

34. (Currently Amended) The apparatus of Claim 32, wherein the first critical region further 
includes logic to: 

s e l e ctiv e ly set a flag to indicate that critical region work is not being performed in 
response to the critical region work completing; and 

set to zero the count of the number of times the first critical region was interrupted. 

35. (Original) The apparatus of Claim 29 further comprising logic to mark the thread as 
having been interrupted during the first critical region. 

36. (Original) The apparatus of Claim 29, further comprising logic to indicate that the thread 
is not operating in a critical region. 

37. (Currently Amended) A system comprising: 

a first storage subsystem and a second storage subsystem; 

a first circuit card including first circuitry capable of being coupled to the first storage 
subsystem, wherein the first circuitry further includes an I/O controller device, the I/O controller 
device comprising: 

a processor; 
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a memory device, wherein the memory device includes code segments that 
instruct the processor to: 

interrupt p e rmit a thread to bo interrupted during a first critical region^ 

int e rrupt th e thread with an interrupt routine, and 

s e l e ctively set the thread to restart at a beginning of the first critical 
region in response to an indication that the thread operates in a critical region; 
and 

a second circuit card including second circuitry capable of being coupled to the second 
storage subsystem , wherein the thread is to avoid disabling all interrupts before it enters the first 
critical region and avoid re-enabling the interrupts after exiting the first critical region . 

38. (Original) The system of Claim 37, wherein the second circuit includes an I/O controller device. 

39. (Original) The system of Claim 37, wherein the first storage subsystem and the second storage 
subsystem each comprise one or more respective mass storage devices. 

40. (Original) The system of claim 37, wherein: 

the first storage subsystem comprises a redundant array of inexpensive disks (RAID); and 
the second storage subsystem comprises a tape mass storage system. 

4 1 . (Original) The system of claim 37, further comprising: 

a circuit board coupled to the bus, wherein the circuit board comprising a bus, memory, 
and a host processor; and 

the first circuit card and the second circuit card are capable of being coupled to the bus. 

42. (Original) The system of Claim 41, wherein the bus complies with PCI. 



